# **PIC16C715**

### In-Circuit Serial Programming (ICSP<sup>TM</sup>) for PIC16C715 OTP MCUs

This document includes the programming specifications for the following devices:

PIC16C715

## 1.0 PROGRAMMING THE PIC16C715

The PIC16C715 can be programmed using a serial method. In serial mode the PIC16C715 can be programmed while in the users system. This allows for increased design flexibility. This programming specification applies to PIC16C715 devices in all packages.

### 1.1 <u>Hardware Requirements</u>

The PIC16C715 requires two programmable power supplies, one for VDD (2.0V to 6.5V recommended) and one for VPP (12V to 14V). Both supplies should have a minimum resolution of 0.25V.

#### 1.2 **Programming Mode**

The programming mode for the PIC16C715 allows programming of user program memory, special locations used for ID, and the configuration word for the PIC16C715.

#### Pin Diagrams



#### PIN DESCRIPTIONS (DURING PROGRAMMING): PIC16C715

|          | During Programming |          |                   |  |  |  |  |
|----------|--------------------|----------|-------------------|--|--|--|--|
| Pin Name | Pin Name           | Pin Type | Pin Description   |  |  |  |  |
| RB6      | CLOCK              | ı        | Clock input       |  |  |  |  |
| RB7      | DATA               | I/O      | Data input/output |  |  |  |  |
| MCLR/Vpp | VPP                | Р        | Programming Power |  |  |  |  |
| VDD      | VDD                | Р        | Power Supply      |  |  |  |  |
| Vss      | Vss                | Р        | Ground            |  |  |  |  |

Legend: I = input, O = Output, P = Power

ICSP is a trademark of Microchip Technology Inc.

#### 2.0 PROGRAM MODE ENTRY

#### 2.1 User Program Memory Map

The user memory space extends from 0x0000 to 0x1FFF (8K). Table 2-1 shows actual implementation of program memory in the PIC16C715 family.

When the PC reaches the last location of the implemented program memory, it will wrap around and address a location within the physically implemented memory (Figure 2-1).

In programming mode the program memory space extends from 0x0000 to 0x3FFF, with the first half (0x0000-0x1FFF) being user program memory and the second half (0x2000-0x3FFF) being configuration memory. The PC will increment from 0x0000 to 0x1FFF and wrap to 0x000 or 0x2000 to 0x3FFF and wrap around to 0x2000 (not to 0x0000). Once in configuration memory, the highest bit of the PC stays a '1', thus always pointing to the configuration memory. The only way to point to user program memory is to reset the part and reenter program/verify mode, as described in Section 2.3.

In the configuration memory space, 0x2000-0x20FF are utilized. When in a configuration memory, as in the user memory, the 0x2000-0x20FF segment is repeatedly accessed as PC exceeds 0x20FF (Figure 2-1).

TABLE 2-1: IMPLEMENTATION OF PROGRAM MEMORY IN THE PIC16C715

| Device    | Program Memory<br>Size | Access to<br>Program<br>Memory |
|-----------|------------------------|--------------------------------|
| PIC16C715 | 0x000-0x7FF (2K)       | PC<10:0>                       |

A user may store identification information (ID) in four ID locations. The ID locations are mapped in [0x2000: 0x2003]. It is recommended that the user use only the six least significant bits of each ID location where the least two significant bits are the parity bits. In some devices, the ID locations read-out in a scrambled fashion after code protection is enabled. For these devices, it is recommended that ID location is written as

"11 1111 1000 bbbb pp"

where 'bbbb' is ID information.

**Note:** All other locations are reserved and should not be programmed.

In other devices, the ID locations read out normally, even after code protection. To understand how the devices behave, refer to Table 4-1.

Note: ID's require parity clocked in/out but not checked.

To understand the scrambling mechanism after code protection, refer to Section 4.1.

FIGURE 2-1: PROGRAM MEMORY MAPPING



#### 2.2 **Program Memory Parity**

The PIC16C715 has on-chip parity bits that can be used to verify the contents of the program memory during runtime. Parity bits may be useful in applications in order to increase overall reliability of the system.

Due to the on-chip parity bits the entire program memory word has been enlarged to 16 bits.

The user is responsible to generate and program the correct parity for a given program memory word. The two parity bits are computed on alternating bits of the program word. One computation is performed using even parity, the other using odd parity as shown in Figure 2-2.

FIGURE 2-2: EPROM MEMORY WITH PARITY CHECKING



#### 2.3 **Program/Verify Mode**

The program/verify mode is entered by holding pins RB6 and RB7 low while raising MCLR pin from VIL to VIHH (high voltage). Once in this mode the user program memory and the configuration memory can be accessed and programmed in serial fashion. The mode of operation is serial, and the memory that is accessed is the user program memory. RB6 is a Schmitt Trigger input in this mode.

The sequence that enters the device into the programming/verify mode places all other logic into the reset state (the MCLR pin was initially at VIL). This means that all I/O are in the reset state (Hi-impedance inputs).

Note: The MCLR pin should be raised as quickly as possible from VIL to VIHH. this is to ensure that the device does not have the PC incremented while in valid operation range.

#### 2.3.1 SERIAL PROGRAM/VERIFY OPERATION

The RB6 pin is used as a clock input pin, and the RB7 pin is used for entering command bits and data input/output during serial operation. To input a command, the clock pin (RB6) is cycled 6 times. Each command bit is latched on the falling edge of the clock with the least significant bit (LSB) of the command being input first. The data on pin RB7 is required to have a minimum setup and hold time of 100 ns with respect to the falling edge of the clock. Commands that have data associated with them (read and load) are specified to have a minimum delay of 1 µs between the command and the data. After this delay the clock pin is cycled 18 times with the first cycle being a start bit and the last cycle being a stop bit. Data is also input and output LSb first. Therefore, during a read operation the LSb will be transmitted from pin RB7 on the rising edge of the second cycle, and during a load operation the LSb will be latched on the falling edge of the second cycle. A minimum 1 µs delay is also specified between consecutive commands.

#### 2.3.2 LOAD CONFIGURATION

After receiving this command, the program counter (PC) will be set to 0x2000. By then applying 18 cycles to the clock pin, the chip will load 16-bits a "data word" as described above, to be programmed into the configuration memory. A description of the memory mapping schemes for normal operation and configuration mode operation is shown in Figure 2-1. After the configuration memory is entered, the only way to get back to the user program memory is to exit the program/verify test mode by taking MCLR low (VIL).

TABLE 2-2: COMMAND MAPPING (SERIAL OPERATION)

| Command                       | Mapping (msb lsb) | Data                           |
|-------------------------------|-------------------|--------------------------------|
| Load Data, Set PC = 2000h     | x x 0 0 0 x       | start_bit, data (16), stop_bit |
| Load Data for Program Memory  | X X 0 0 1 X       | start_bit, data (16), stop_bit |
| Read Data from Program Memory | X X 0 1 0 X       | start_bit, data (16), stop_bit |
| Increment Address             | X X 0 1 1 X       |                                |
| Begin Programming             | x x 1 0 0 x       |                                |
| End Programming               | x x 1 1 1 x       |                                |





#### 2.3.2.1 LOAD DATA

After receiving this command, the chip will load in a 16-bit "data word" when 18 cycles are applied, as described previously. A timing diagram for the load data command is shown in Figure 5-1.

#### 2.3.2.2 READ DATA

After receiving this command, the chip will transmit data bits out of the memory currently accessed starting with the second rising edge of the clock input. The RB7 pin will go into output mode on the second rising clock edge, and it will revert back to input mode (hi-impedance) after the 18th rising edge. A timing diagram of this command is shown in Figure 5-2.

#### 2.3.2.3 INCREMENT ADDRESS

The PC is incremented when this command is received. A timing diagram of this command is shown in Figure 5-3.

#### 2.3.2.4 BEGIN PROGRAMMING

A load command (load configuration or load data) must be given before every begin programming command. Programming of the appropriate memory (test program memory or user program memory) will begin after this command is received and decoded. Programming should be performed with a series of  $100~\mu s$  programming pulses. A programming pulse is defined as the time between the begin programming command and the end programming command.

#### 2.3.2.5 END PROGRAMMING

After receiving this command, the chip stops programming the memory (configuration program memory or user program memory) that it was programming at the time.

### 2.4 Programming Algorithm Requires Variable VDD

The PIC16C715 uses an intelligent algorithm. The algorithm calls for program verification at VDDmin as well as VDDmax. Verification at VDDmin guarantees good "erase margin". Verification at VDDmax guarantees good "program margin".

The actual programming must be done with VDD in the VDDP range (4.75 - 5.25V).

VDDP = VCC range required during programming.

VDD min. = minimum operating VDD spec for the part.

VDDmax = maximum operating VDD spec for the part.

Programmers must verify the PIC16C715 at its specified VDDmax and VDDmin levels. Since Microchip may introduce future versions of the PIC16C715 with a broader VDD range, it is best that these levels are user selectable (defaults are ok).

**Note:** Any programmer not meeting these requirements may only be classified as "prototype" or "development" programmer but not a "production" quality programmer.

#### 3.0 CONFIGURATION WORD

The PIC16C715 family members have several configuration bits. These bits can be programmed (reads '0') or left unprogrammed (reads '1') to select various device configurations. Figure 3-1 provides an overview of configuration bits.

Note: Parity bits are clocked in/out but not

checked.

#### FIGURE 3-1: CONFIGURATION WORD BIT MAP

| Bit<br>Number: | 15  | 14  | 13  | 12  | 11  | 10  | 9     | 8     | 7   | 6   | 5     | 4    | 3     | 2     | 1 | 0 |
|----------------|-----|-----|-----|-----|-----|-----|-------|-------|-----|-----|-------|------|-------|-------|---|---|
| PIC16C715      | CP1 | CP0 | CP1 | CP0 | CP1 | CP0 | MPEEN | BODEN | CP1 | CP0 | PWRTE | WDTE | FOSC1 | FOSC0 | Р | Р |

bit 9: MPEEN, Memory Parity Error Enable

1: Memory parity Checking is enabled

0: Memory Parity Checking is disabled

bit 7-6: CP1:CP0, Code Protect

| Device    | CP1 | CP0 | Code Protection            |
|-----------|-----|-----|----------------------------|
| PIC16C715 | 0   |     | All memory protected       |
|           | 0   |     | Upper 3/4 memory protected |
|           | 1   |     | Wpper 1/2 memory protected |
|           | 1   |     | Code protection off        |

bit 8: BODEN, Brown-out Enable bit

1 = Enabled

0 = Disabled

bit 5: **PWRTE**, Power-up Timer Enable bit

0 = Power up timer enabled

1 = Power up timer disabled

bit 4: WDTE, WDT Enable bit

1 = WDT enabled

0 = WDT disabled

bit 3-2: FOSC1:FOSC0, Oscillator Selection bit

11: RC oscillator

10: HS oscillator

01: XT oscillator

00: LP oscillator

bit 1-0: Parity bits for Configuration Word

#### 4.0 CODE PROTECTION

The program code written into the EPROM can be protected by writing to the CP0 & CP1 bits of the configuration word.

**Note:** Code protection should be the last test for a device, since the areas protected cannot be reprogrammed. Code protection is permanent for any device.

### 4.1 Programming Locations 0x000 to 0x7FF after Code Protection

For all PIC16C715 devices, once code protection is enabled, all protected segments read '0's (or "garbage values") and are prevented from further programming. All unprotected segments, including ID locations and configuration word, read normally. These locations can be programmed.

#### 4.2 Embedding Configuration Word and ID Information in the Hex File

To allow portability of code, the programmer is required to read the configuration word and ID locations from the hex file when loading the hex file. If configuration word information was not present in the hex file then a simple warning message may be issued. Similarly, while saving a hex file, configuration word and ID information must be included. An option to not include this information may be provided.

Microchip Technology Inc. feels strongly that this feature is important for the benefit of the end customer.

#### TABLE 4-1: CONFIGURATION WORD

#### PIC16C715

#### To code protect:

- Protect all memory 000000XX00XXXXXX
- Protect upper 1/2 memory 101010XX10XXXXXX
- Protect upper 3/4 memory 010101xx01xxxxxxx
- No code protection 1111111XX11XXXXXX

| Program Memory Segment         | R/W in Protected Mode           | R/W in Unprotected Mode         |
|--------------------------------|---------------------------------|---------------------------------|
| Configuration Word (0x2007)    | Read Unscrambled, Write Enabled | Read Unscrambled, Write Enabled |
| Unprotected memory segment     | Read Unscrambled, Write Enabled | Read Unscrambled, Write Enabled |
| Protected memory segment       | Read All 0's, Write Disabled    | Read Unscrambled, Write Enabled |
| ID Locations (0x2000 : 0x2003) | Read Unscrambled, Write Enabled | Read Unscrambled, Write Enabled |

#### 4.3 Checksum

#### 4.3.1 CHECKSUM CALCULATIONS

Checksum is calculated by reading the contents of the PIC16C715 memory locations and adding up the opcodes up to the maximum user addressable location, e.g., 0x7FF for the PIC16C715. Any carry bits exceeding 16-bits are neglected. Finally, the configuration word (appropriately masked) is added to the checksum. Checksum computation for each member of the PIC16C715 devices is shown in Table 4-2.

The checksum is calculated by summing the following:

- · The contents of all program memory locations
- The configuration word, appropriately masked
- Masked ID locations (when applicable)

The least significant 16 bits of this sum is the checksum.

The following table describes how to calculate the checksum for each device. Note that the checksum calculation differs depending on the code protect setting. Since the program memory locations read out differently depending on the code protect setting, the table describes how to manipulate the actual program mem-

ory values to simulate the values that would be read from a protected device. When calculating a checksum by reading a device, the entire program memory can simply be read and summed. The configuration word and ID locations can always be read.

Note that some older devices have an additional value added in the checksum. This is to maintain compatibility with older device programmer checksums.

TABLE 4-2: CHECKSUM COMPUTATION

| Device    | Code<br>Protect | Checksum*                                       | Blank<br>Value | 0x25E6 at<br>0 and max<br>address |
|-----------|-----------------|-------------------------------------------------|----------------|-----------------------------------|
| PIC16C715 | OFF             | SUM[0x0000:0x07FF] + (CONFIG & 0x3FFF)          | 0x37FF         | 0x03CD                            |
|           | 1/2             | SUM[0x0000:0x03FF] + (CONFIG & 0x3FFF) + SUM_ID | 0x5EEE         | 0x10A3                            |
|           | 3/4             | SUM[0x0000:0x01FF] + (CONFIG & 0x3FFF) + SUM_ID | 0x4BDE         | 0xFD93                            |
|           | ALL             | (CONFIG & 0x3FFF) + SUM_ID                      | 0x38CE         | 0x049C                            |

Legend: CFGW = Configuration Word

SUM[a:b] = [Sum of locations a through b inclusive]

SUM\_ID = ID locations masked by 0xF then made into a 16-bit value with ID0 as the most significant nibble. For example, ID0 = 0x12, ID1 = 0x37, ID2 = 0x4, ID3 = 0x26, then SUM\_ID = 0x2746.

<sup>\*</sup>Checksum = [Sum of all the individual expressions] MODULO [0xFFFF]

<sup>+ =</sup> Addition

<sup>&</sup>amp; = Bitwise AND

#### 5.0 PROGRAM/VERIFY MODE ELECTRICAL CHARACTERISTICS

### TABLE 5-1: AC/DC CHARACTERISTICS TIMING REQUIREMENTS FOR PROGRAM/VERIFY TEST MODE

#### **Standard Operating Conditions**

Operating Temperature: +10°C ≤ TA ≤ +40°C, unless otherwise stated, (20°C recommended)

Operating Voltage:  $4.5V \le VDD \le 5.5V$ , unless otherwise stated.

| Parameter No. | Sym. Characteristic |                                              | Min. | Тур. | Max. | Units | Conditions |
|---------------|---------------------|----------------------------------------------|------|------|------|-------|------------|
| General       |                     |                                              |      |      |      |       |            |
| P1            | VDDP                | Supply voltage during programming            | 4.75 | 5.0  | 5.25 | V     |            |
| P2            | IDDP                | Supply current (from VDD) during programming | _    | _    | 20   | mA    |            |

Note 1: Program must be verified at the minimum and maximum VDD limits for the part.

Note 2: VIHH must be greater than VDD + 4.5V to stay in programming/verify mode.

### TABLE 5-1: AC/DC CHARACTERISTICS TIMING REQUIREMENTS FOR PROGRAM/VERIFY TEST MODE

#### **Standard Operating Conditions**

Operating Temperature: +10°C ≤ TA ≤ +40°C, unless otherwise stated, (20°C recommended)

Operating Voltage:  $4.5V \le VDD \le 5.5V$ , unless otherwise stated.

| Parameter No. | Sym.  | Characteristic                         | Min.      | Тур. | Max.   | Units | Conditions            |
|---------------|-------|----------------------------------------|-----------|------|--------|-------|-----------------------|
| P3            | VDDV  | Supply voltage during verify           | VDDmin    | _    | VDDmax | V     | Note 1                |
| P4            | VIHH1 | Voltage on MCLR/VPP during programming | 12.75     | 1    | 13.25  | V     | Note 2                |
| P5            | VIHH2 | Voltage on MCLR/VPP during verify      | VDD + 4.0 | _    | 13.5   |       |                       |
| P6            | IPP   | Programming supply current (from VPP)  | _         |      | 50     | mA    |                       |
| P9            | ViH1  | (RB6, RB7) input high level            | 0.8 VDD   | _    | _      | V     | Schmitt Trigger input |
| P8            | VIL1  | (RB6, RB7) input low level             | 0.2 VDD   |      | _      | ٧     | Schmitt Trigger input |

| Serial Prog | ram Veri | fy                                                                                                 |     |   |     |    |  |
|-------------|----------|----------------------------------------------------------------------------------------------------|-----|---|-----|----|--|
| P1          | TR       | MCLR/VPP rise time (VSS to VHH) for test mode entry                                                | _   | _ | 8.0 | μs |  |
| P2          | TF       | MCLR Fall time                                                                                     | _   | _ | 8.0 | μs |  |
| P3          | TSET1    | Data in setup time before clock ↓                                                                  | 100 | _ | _   | ns |  |
| P4          | THLD1    | Data in hold time after clock $\downarrow$                                                         | 100 | _ | _   | ns |  |
| P5          | TDLY1    | Data input not driven to next clock input (delay required between command/data or command/command) | 1.0 | _ | _   | μs |  |
| P6          | TDLY2    | Delay between clock ↓ to clock ↑ of next command or data                                           | 1.0 | _ | _   | μs |  |
| P7          | TDLY3    | Clock ↑ to date out valid (during read data)                                                       | 200 | _ | _   | ns |  |
| P8          | THLD0    | Hold time after MCLR ↑                                                                             | 2   | _ | _   | μs |  |

Note 1: Program must be verified at the minimum and maximum VDD limits for the part.

Note 2: VIHH must be greater than VDD + 4.5V to stay in programming/verify mode.

FIGURE 5-1: \LOAD DATA COMMAND (PROGRAM/VERIFY)



FIGURE 5-2: READ DATA COMMAND (PROGRAM/VERIFY)



FIGURE 5-3: INCREMENT ADDRESS COMMAND (PROGRAM/VERIFY)



|        |  | <br>· • 9 · · · | ······9 |
|--------|--|-----------------|---------|
| NOTES: |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |
|        |  |                 |         |



### WORLDWIDE SALES & SERVICE

#### **AMERICAS**

#### **Corporate Office**

Microchip Technology Inc. 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 602-786-7200 Fax: 602-786-7277 Technical Support: 602 786-7627 Web: http://www.microchip.com

#### Atlanta

Microchip Technology Inc. 500 Sugar Mill Road, Suite 200B Atlanta, GA 30350 Tel: 770-640-0034 Fax: 770-640-0307

#### **Boston**

Microchip Technology Inc. 5 Mount Royal Avenue Marlborough, MA 01752 Tel: 508-480-9990 Fax: 508-480-8575

#### Chicago

Microchip Technology Inc. 333 Pierce Road, Suite 180 Itasca, IL 60143 Tel: 630-285-0071 Fax: 630-285-0075

#### **Dallas**

Microchip Technology Inc. 14651 Dallas Parkway. Suite 816 Dallas, TX 75240-8809 Tel: 972-991-7177 Fax: 972-991-8588

#### Dayton

Microchip Technology Inc. Two Prestige Place, Suite 150 Miamisburg, OH 45342 Tel: 937-291-1654 Fax: 937-291-9175

#### Los Angeles

Microchip Technology Inc. 18201 Von Karman, Suite 1090 Irvine, CA 92612 Tel: 714-263-1888 Fax: 714-263-1338

#### **New York**

Microchip Technology Inc. 150 Motor Parkway, Suite 416 Hauppauge, NY 11788 Tel: 516-273-5305 Fax: 516-273-5335

#### San Jose

Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955

#### **Toronto**

Microchip Technology Inc. 5925 Airport Road, Suite 200 Mississauga, Ontario L4V 1W1. Canada Tel: 905-405-6279 Fax: 905-405-6253

#### ASIA/PACIFIC

#### **Hong Kong**

Microchip Asia Pacific RM 3801B, Tower Two Metroplaza 223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2-401-1200 Fax: 852-2-401-3431

Microchip Technology Inc. India Liaison Office No. 6, Legacy, Convent Road Bangalore 560 025, India Tel: 91-80-229-4036 Fax: 91-80-559-9840

#### Korea

Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea Tel: 82-2-554-7200 Fax: 82-2-558-5934

#### Shanghai

Microchip Technology RM 406 Shanghai Golden Bridge Bldg. 2077 Yan'an Road West, Hong Qiao District Shanghai, PRC 200335 Tel: 86-21-6275-5700

#### Singapore

Fax: 86 21-6275-5060

Microchip Technology Taiwan Singapore Branch 200 Middle Road #10-03 Prime Centre Singapore 188980 Tel: 65-334-8870 Fax: 65-334-8850

#### Taiwan, R.O.C

Microchip Technology Taiwan 10F-1C 207 Tung Hua North Road Taipei, Taiwan, ROC

#### Tel: 886 2-717-7175 Fax: 886-2-545-0139

#### **EUROPE**

#### **United Kingdom**

Arizona Microchip Technology Ltd. Unit 6, The Courtyard Meadow Bank, Furlong Road Bourne End, Buckinghamshire SL8 5AJ Tel: 44-1628-851077 Fax: 44-1628-850259

Arizona Microchip Technology SARL Zone Industrielle de la Bonde 2 Rue du Buisson aux Fraises 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

#### Germany

Arizona Microchip Technology GmbH Gustav-Heinemann-Ring 125 D-81739 Müchen, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44

#### Italy

Arizona Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-39-6899939 Fax: 39-39-6899883

#### JAPAN

Microchip Technology Intl. Inc. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa 222 Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122

7/29/97



All rights reserved. ©1997, Microchip Technology Incorporated, USA. 8/97



Printed on recycled paper.

Information contained in this publication regarding device applications and the like is intended for suggestion only and may be superseded by updates. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchip's products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights. The Microchip logo and name are registered trademarks of Microchip Technology Inc. in the U.S.A. and other countries. All rights reserved. All other trademarks mentioned herein are the property of their respective companies.